<template>
  <el-dialog title="编辑" :modelValue="popShow" width="30%" center :show-close="false">
    <el-form :model="editData" ref="ruleFromRef">
      <el-form-item label="课程标题" prop="title" required>
        <el-input v-model='editData.title' />
      </el-form-item>
      <el-form-item label="课程价格" prop="price" required>
        <el-input v-model='editData.price' />
      </el-form-item>
      <el-form-item>
        <el-button @click="confirmClick('cancel')">取消</el-button>
        <el-button type="primary" @click="submitForm(ruleFromRef)">确认</el-button>
      </el-form-item>
    </el-form>
  </el-dialog>
</template>
<script setup>
  import { defineProps, reactive, ref } from 'vue';
  const { popShow, message, confirmClick } = defineProps(['popShow', 'message', 'confirmClick'])
  /**
   * 编辑组件维护的数据
   */
  const editData = reactive({
    title: message.title,
    price: message.price,
    id: message.id
  })
  /**
   * 表单校验
   */
  const ruleFromRef = ref(null)
  const submitForm = async (formEl) => {
    if (!formEl) return
    await formEl.validate((valid, fields) => {
      if (valid) {
        confirmClick({ title: editData.title, price: editData.price, id: editData.id })
      } else {
        console.log('error submit!', fields)
      }
    })
  }
  
  </script>
  <style lang='less' scoped>
  .dialog-footer button:first-child {
    margin-right: 10px;
  }
  
  :deep(.el-form-item__label) {
    width: 80px !important;
  }
  
  :deep(.el-form-item__content) {
    justify-content: center;
    margin-left: 0 !important;
  }
  </style>